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(54) Vehicle navigation system 

(57) An on-board automobile navigation system 
provides advisory information to the driver based on 
real-time traffic information and a learned commute 
route. The system empirically determines a commute 
route based on historical travel data of the vehicle. The 
system further receives real-time traffic information via 
a wireless link. The real-time traffic information may 
include information relating to traffic accidents, con- 
struction, and other traffic problems and the locations of 
such problems. At power up, the system automatically 
determines whether the present day and time are within 
a previously defined commute time window and, if so, 
prompts the driver to accept or decline a previously 
defined commute destination. The system automatically 
receives the real-time traffic information and compares 
the. location information associated with any traffic prob- 
lems to the commute route. If the system determines 
that the location of a traffic problem falls on or near the 
commute route, then the system outputs an appropriate 
notification to the user and, if possible, computes an 
alternative route. 
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on this information. The system then compares the 
commute route to traffic advisories received in real-time 
traffic information and notifies the driver if there is a traf- 
fic incident on or near his commute route. 
[0008] Referring now to Figure 1 , an onboard automo- 
bile navigation system 1 is installed in an automobile 2. 
The navigation system 1 performs guidance functions 
for guiding the driver of the automobile 2 to a selected 
destination, such as the functions described above (see 
"BACKGROUND OF THE INVENTION"). The naviga- 
tion system 1 includes a first antenna 4 for communicat- 
ing with a GPS satellite 3, and a second antenna 5 for 
receiving real-time traffic information (RTI) messages 
from a remote transmission source. 
[0009] The RTI messages are created by a traffic 
management center (TMC) 6, which receives traffic 
information from a variety of sources. The traffic infor- 
mation may include, for example, accident messages, 
road closure messages, speed information relating to 
various sections of roadway, and construction mes- 
sages. The sources of such data may be, for example, 
loop detectors, automatic vehicle identification tags, his- 
torical traffic analysis, and theoretical information about 
traffic capacity to determine the level of traffic conges- 
tion. The TMC 6 may also generate RTI messages 
based upon incident information it receives from police, 
fire, or highway departments. The TMC 6 consolidates 
the data it receives and converts the data into RTI mes- 
sages having a standard format. The TMC 6 then trans- 
mits the RTI messages to a local radio station 7 over 
any suitable data communication link, such as conven- 
tional (POTS) telephone lines, ISDN lines, T1 lines, etc. 
[0010] The local radio station 7 reserves a section of 
its frequency modulation (FM) transmission spectrum 
for the broadcasting of the RTI messages. The radio 
station 7, therefore, broadcast the RTI messages in the 
reserved portion of its FM transmission spectrum. The 
broadcast RTI messages are received and decoded by 
the on-board navigation system 1 in the automobile 2. 
Note that techniques are known to those skilled in the 
art for generating and transmitting RTI messages and 
for receiving and decoding such messages. The RTI 
messages include location coordinates (e.g., latitude 
and longitude) of traffic incidents. Accordingly, the navi- 
gation system 1 compares the location information in 
the RTI messages with the commute route, and, if there 
is a substantial match, outputs an appropriate advisory 
to the driver. 

[0011] Figure 2 iOustrates an embodiment of the nav- 
igation system 1 . As shown, the navigation system 1 
includes a central processing unit (CPU) 10, read-only 
memory (ROM) 11, random access memory (RAM) 12, 
and a mass storage device 13, coupled together by a 
bus system 24. The bus system 24 may represent mul- 
tiple buses, which may be interconnected by various 
bridges, bus controllers, and/or adapters. The CPU 10 
controls operation of the navigationsystem 1 by execut- 
ing instructions stored in either ROtfl 1 1 , RAM 12, mass 



storage device 13, or a combination of these devices. 
Mass storage device 13 stores a map database of 
streets and points of interest for a given geographic 
area. ROM 1 1 is non-volatile memory, a portion of which 

5 may be erasable and reprogrammable. For example, 
ROM 1 1 may include flash memory electrically-erasa- 
ble programmable ROM (EEPROM), or any other suita- 
ble form, of programmable-erasable non-volatile 
memory. Mass storage device 13 may be embodied as 

io a magnetic, optical, magneto-optical, or any other type 
of non-volatile storage device suitable for storing large 
quantities of data. 

[001 2] The navigation system 1 also includes a sensor 
subsystem 27. The sensor subsystem includes an 

15 angular velocity sensor (e.g., a gyroscope)19. a dis- 
tance sensor (i.a, odometer) 20, a GPS receiver 21, 
and an FM receiver/decoder, each coupled to the bus 
system 24. Note that the GPS receiver 21 may be 
replaced by appropriate components for use with other 

20 types of precise positioning systems, such as LORAN- 
C, etc., or it may simply be omitted. Each of the sensors 
1 9-22 may be coupled to the bus system 24 by appropri- 
ate interface circuitry, such as analog-to-digital convert- 
ers and appropriate signal conditioning circuitry. The 

25 FM receiver/decoder receives and decodes the broad- 
cast RTI messages and outputs data representing the 
RTI messages onto the bus system 24 in a format which 
can be used by the CPU 1 0 and stored in any of storage 
devices 11, 12, and 13. Data output by the angular 

30 velocity sensor 19, the distance sensor 20, and GPS 
receiver 21 are used by the navigation system 1 in con- 
junction with the street map database to compute the 
current location of the vehicle as the vehicle travels. 
[0013] The navigation system 1 also includes an 

35 input/output (I/O) subsystem 26. The I/O subsystem 26 
includes an input subsystem 1 4, an audio controller 1 5, 
and a display controller 1 7, each coupled to the bus sys- 
tem 24. The I/O subsystem 26 further includes an audio 
speaker 1 6 coupled to and controlled by audio controller 

40 15 and a display device 1 8 coupled to and controlled by 
display controller 17. The input subsystem 14 includes 
various user-operable controls, such as buttons and/or 
switches, using which the driver can operate the naviga- 
tion system 1, such as to enter a destination, select a 

45 display mode, etc. The navigation system 1 outputs dig- 
itized or synthesized audio navigation instructions to the 
user via the audio speaker 16. visual output which may 
include a map display and/or navigation instructions, is 
provided to the driver via the display device. The display 

so device 18 may be a liquid crystal display (LCD), a cath- 
ode ray tube (CRT), or any other suitable form of display 
device. 

[0014] Note that aspects of the present invention may 
be embodied in software, as will be apparent from this 
55 description. That is, aspects of the present invention 
may be carried out in a computer system, such as navi- 
gation system .1, in response to its CPU executing 
sequences of instructions contained in memory. The 
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instructions may be executed from RAM, ROM t a mass 
storage device, or a combination of such devices. Also, 
in various embodiments of the present invention, hard- 
wired circuitry may be used in place of, or in combina- 
tion with, software instructions to implement the present s 
invention. Thus, the present invention is not limited to 
any specific combination of hardware circuitry and soft- 
ware, nor to any particular source for the instructions 
executed by a computer system. 

[0015] For some applications, it may be desirable to 10 
have an on-board navigation system with only basic 
functionality, to reduce the complexity and cost of the 
system. Accordingly, certain embodiments of the navi- 
gation system 1 may not include all of the above-men- 
tioned components. For example, if a given application is 
does not require the navigation system to output 
detailed navigation instructions, then the audio control- 
ler 15, speaker 16, display controller 17, and display 
device 18 may be replaced with simpler devices, such 
as a warning light and/or a simple a buzzer. Further, it 20 
may not be necessary to include a GPS receiver 24, as 
noted above. 

[001 6] Figure 3 illustrates an overall routine by which 
the navigation system 1 j^n^p^pare received RTI 
messages to a learned commute route and output a 2s 
notification to the driver when there is a traffic problem 
on or near the commute route. In response to the navi- 
gation system being powered up (which may occur 
automatically whenever the automobile is started), at 
301 the navigation system 1 determines whether the 30 
present time and day of the week are within a previously 
defined commute time window. The commute time win- 
dow, which defines the typical commute times of the 
user, may be a default, or it may have been input previ- 
ously by the user through a scheduling function of the 35 
navigation system 1 . The commute time window may 
be, for example, one or more user-specified periods of 
time during user-specified days of the week. If the 
present day and time fall within the commute time win- 
dow, then at 302 the system 1 prompts the user to 40 
accept or decline the commute destination; otherwise, 
the routine ends. The commute destination may be a 
location that has been determined automatically by the 
system 1 based on the learned commute route or previ- 
ously input or selected by the user, and then stored in 45 
non-volatile memory. If the user accepts the commute 
destination at 303. then at 304 the navigation system 1 
uses the commute destination as the currently selected 
destination and begins to receive and decode the RTI 
messages that have been transmitted from the remote so 
source. If the user does not accept the commute desti- 
nation, the routine ends. 

[0017] Note that the use of the scheduled commute 
time window avoids the user's having to specify his 
commute destination and other parameters, such as 55 
guidance criteria, calculation criteria, etc., each day 
before beginning his commute. - t Instead, the user can 
activate commute guidance and recall previously stored 



user preferences with just the touch of a button by 
accepting the commute destination. Hence, very few 
user inputs are required to operate the system. 
[0018] Upon receiving and decoding the RTI mes- 
sages, at 305 location information relating to traffic 
problems and embedded in the RTI messages is com- 
pared by the navigation system to the learned commute 
route. Next, at 306 the system 1 determines whether the 
location information in the RTI messages matches or is 
close to (substantially matches) , the commute route. If 
there is no match or substantial match, then the routine 
repeats from 304. If, however, there is a match or a sub- 
stantial match, then at 307, the system outputs a notifi- 
cation message indicating to the driver that there is a 
problem on or close to the drivers commute route. This 
message may be in the form of text, graphics and/or 
audio, or, as indicated above, it may be a more simple 
audio or visual indication. Next, at 308, the navigation 
system 1 determines whether any alternate commute 
routes are available. Any suitable technique can be 
used for computing the best alternative route; note that 
the system 1 already knows the destination of the com- 
mute route and the present location of the vehicle. If no 
alternate route to the destination can be identified, then 
the routine repeats from 304. If an alternate route is 
identified, then the system 1 prompts the driver to 
accept or decline an alternate route at 309. Note that 
numerous variations on the above-described routine 
and the routines described below are possible. 
[0019] Various approaches can be used for computing 
a commute route in accordance with the present inven- 
tion. For example, the navigation system 1 may apply a 
statistical analysis to the travel history of the automo- 
bile. Figure 4 illustrates a routine by which a commute 
route can be determined, according to one embodi- 
ment At 401 , when the navigation system 1 is operated 
within the previously specified (or default) commute 
time window, the system 1 computes the location of the 
vehicle at multiple locations as the vehicle travels, and 
associates time stamps with the data representing each 
computed location. Thus, the system 1 acquires data 
representing a chronology of the vehicles travels. This 
chronology data is stored in the navigation system 1 in 
an appropriate storage device, such as RAM 1 1 or 
mass storage device 13. Next, at 402, the stored loca- 
tion and time stamp data are referenced against the 
stored street map database to generate the commute 
route. Note that 402 may be performed in response to a 
power up of the navigation system 1 or in response to 
an impending power down. The commute route is then 
saved to the appropriate storage device at 403. At 404, 
(optionally), the commute route is used to update or 
modify a composite commute route that has been gen- 
erated from position and time stamp data acquired on 
multiple days. It will be recognized that the more data 
that is acquired, the more accurate the composite com- 
mute route becomes. 

[0020] Figure 5 illustrates an alternative routine for 
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determining a commute route. The routine of Figure 5 is 
based upon the generation of a histogram of data repre- 
senting the travels of the vehicle. In particular, the sys- 
tem compiles a histogram consisting of a number of 
bins, each representing one street segment of the 5 
stored map database. In other embodiments, the histo- 
gram may be based upon information other than street 
segments, such as latitude and longitude, etc. Thus, at 
501 , the system 1 determines whether the present time 
falls within a previously-defined (or default) commute 70 
time window. Next, at 502. the current location of the 
vehicle is computed by the navigation system 1 at regu- 
lar time intervals during the commute time window. 
Each computed location of the vehicle is associated 
with a street segment from the map database at 503. 15 
Accordingly, at 504 for each computed location of the 
vehicle, the appropriate street segment bin of the histo- 
gram is incremented by one. If enough data has been 
acquired to generate a statistically useful result at 505, 
then at 506 the system 1 computes, a commute route (or 20 
updates a previously-computed commute route) based 
upon the histogram, rf the amount of acquired data is 
not sufficient, then the routine repeats from 501. 
[0021J Thus, an on-board automobile navigation sys- 
tem that provides traffic advisory information to a driver 25 
based on real-time traffic information and a learned 
commute route has been described. Although the 
present invention has been described with reference to 
specific exemplary embodiments, it will be evident that 
various modifications and changes may be made to 30 
these embodiments without departing from the broader 
spirit and scope of the invention as set forth in the 
claims. Accordingly, the specification and drawings are 
to be regarded in an illustrative sense rather than a 
restrictive sense. 35 

Claims 

1. A method of providing advisory information to a 
driver of a vehicle, the method comprising: 40 

determining a route empirically based on his- 
torical travel data of the vehide; 
receiving real-time traffic information; 
referencing the real-time traffic information .45 
against the route; and 

outputting a notification to the driver if a corre- 
spondence is found between the real-time traf- 
fic information and the route. 

50 

2. A method according to claim 1 , wherein the vehicle 
is an automobile, and wherein said determining 
comprises determining the route empirically based 
on historical travel data of the vehicle and a street 
map database. ss 

3. A method according to claim 1 , further comprising: 



computing an alternate route if a correspond- 
ence is found between the real-time traffic 
information and the route; and 
notifying the driver of the alternate route. 

4. A method according to claim 1 , wherein said deter- 
mining comprises: 

creating a histogram of travel information of the 
automobile; and 

determining the route based on the histogram. 

5. A method according to claim 1, wherein the real- 
time traffic information further comprises informa- 
tion relating to a traffic problem. 

6. A method according to claim 1 , further comprising: 

determining whether a present time is within a 
previously defined time window; 
if the present time is within the previously 
defined time window, outputting a prompt to 
accept or decline a previously defined destina- 
tion; and 

if the previously defined destination is 
accepted, designating the previously defined 
destination as a currently selected destination. 

7. In an on-board navigation system for assisting a 
driver of an automobile in navigating, a method of 
providing advisory information to the driver, the 
method comprising: 

acquiring information on a travel history of the 
automobile; 

identifying a commute route based on the infor- 
mation on the travel history of the automobile 
and a street map database; 
in response to a power-up of the navigation 
system, receiving real-time traffic information 
from a remote source, the real-time traffic infor- 
mation including location information; 
comparing the location information with the 
commute route; and 

outputting a notification to the driver if the loca- 
tion information substantially matches a loca- 
tion on the commute route. 

8. A method according to claim 7, further comprising: 

computing an alternate route if the location 
information substantially matches a location on 
the commute route; and 
notifying the driver of the alternate route. 

9. A method according to claim 7, wherein said acquir- 
ing comprises creating a histogram of locations at 

: which the automobile has traveled, and wherein 
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said identifying comprises identifying the commute 
route based on the histogram. 

10. A method according to daim 7. wherein the real- 
time traffic information further comprises informa- 
tion relating to a traffic problem. 

11. A method according to claim 7, further comprising, 
in response to the power-up of the navigation sys- 
tem: 

determining whether a present time corre- 
sponds to a previously defined time window; 
and 

H the present time corresponds to the previ- 
ously defined time window, recalling a previ- 
ously stored destination. 

1 2. A method according to claim 1 1 , further comprising 
using the previously defined destination as a cur- 
rently selected destination. 



14. An on-board navigation system according to claim 
13, further comprising: 
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15. An on-board navigation system according to claim 
13, wherein the means for determining comprises: 



30 



13. An on-board navigation system for assisting the 
driver of an automobile in navigating, the system 
comprising: 25 



means for storing a street map database; 
means for automatically learning a commute 
route based on historical travel data of the vehi- 
cle and the street map database; 
means for receiving real-time traffic information 
including location information; 
means for referencing the location information 
against the commute route in response to a 
power-up of the navigation system; and 
means for outputting a notification to the driver 
if the location information corresponds to a 
location on the commute route. 



35 



40 



means for computing art alternate route if the 
location information corresponds to a location 
on the commute route; and *s 
means for notifying the driver of the alternate 
route. 



50 



means for creating a histogram of travel data of 
the automobile; and 

means for determining the commute route 
based on the histogram. 55 

16. An on-board navigation system according to claim 
13 f further comprising: 



means for receiving user inputs specifying a 
desired destination; 

means for computing a best route based on the 
street map database and the desired destina- 
tion; and 

means for outputting guidance information 
based on the best route. 

17. An on-board navigation system according to claim 
13, further comprising: 

means for determining whether a present time 
is within a previously defined commute time 
window; 

means for outputting a prompt to accept or 
decline a previously defined commute destina- 
tion if the present time is within the previously 
defined commute time window; and 
means for designating the previously defined 
commute destination as a currently selected 
destination if the previously defined commute 
destination is accepted. 

18. A system for assisting a driver of an automobile in 
navigating, the system comprising: 

a processor for controlling operation of the sys- 
tem; 

an input subsystem coupled to the processor 
for receiving user inputs; 
an output subsystem coupled to the processor 
for outputting guidance information; 
a sensor subsystem coupled to the processor 
for measuring travel parameters of the automo- 
bile; 

a storage device coupled to the processor and 
storing a street map database; and 
a receiver coupled to the processor for receiv- 
ing. real-time traffic information over a wireless 
link; 

wherein the processor is configured to: 

determine a first route empirically based 
on travel data of the automobile and the 
street map database; 

compare location information in the real- 
time traffic information with the first route; 
and 

generate a notification for output to the 
driver if the location information corre- 
sponds to a location along the first route. 

19. A system according to claim 18, wherein the proc- 
essor is further configured to: 

receive an input destination via the input sub- 
system; 

compute a current position of the vehicle based 
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on data from the sensor subsystem; 
compute a second route based on the input 
destination, the map database, and the current 
position of the vehicle; and 
generate the guidance information based on 
the second route; 

20. A system according to claim 19, wherein the proc- 
essor is further configured to: 

compute an alternate route for the first route if 
the location information substantially matches 
a location along the first route; and 
generate a notification for output to the driver of 
the alternate first route. 

21. A system according to claim 19, wherein the proc- 
essor is further configured to: 

generate a histogram of travel information of 
the automobile; and 

determine the first route based on the histo- 
gram. 

22. A system according to claim 18, wherein the proc- 
essor is further configured to: 

determine whether a present time is within a 
previously defined time window; 
output a prompt to accept or decline a previ- 
ously stored destination if the present time is 
within the previously defined commute time 
window. 

23. A system for assisting a driver of an automobile in 
navigating, the system comprising: 

an input subsystem for receiving user inputs; 
an output subsystem for outputting guidance 
information; 
a sensor subsystem; 
_ a storage device storing a street map data- 
base; 

a receiver for receiving real-time traffic informa- 
tion over a wireless link; and 
a processor coupled to the input subsystem, 
the output subsystem, the sensor subsystem, 
the storage device, and the receiver, the proc- 
essor configured to: 



on the first route; 

determine a second route empirically 
based on travel data of the automobile; 
compare location information in the real- 
time traffic information with the second 
route; and 

generate a notification for output to the 
. driver H the location information substan- 
tially matches a location along the second 
route. 

24. A system according to claim 23, wherein the proc- 
essor is further configured to: 

compute an alternate second route if the loca- 
tion information substantially matches a loca- 
tion along the second route; and 
generate a notification for output to the driver of 
the alternate second route. 

25. A system according to claim 23, wherein the proc- 
essor is further configured to: 

generate a histogram of travel information of 
the automobile; and 

determine the second route based on the histo- 
gram. 

26. A system according to claim 23, wherein the proc- 
essor is further configured to: 

determine whether a present time is within a 
previously defined time window; 
if the present time is within the previously 
defined commute time window, designate the 
previously defined commute destination as a 
currently selected destination. 
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compute a current position of the vehicle 
based on data from the sensor subsystem; 
receive an input destination via the input 
subsystem; 

compute a first route based on the input 55 
destination, the map database, and the 
» current position of the. vehicle; 
generate the guidance information based 
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